Dark Mode
Astral.CSS framework also supports dark mode and custom modes
Modern browsers come with a way to detect if a user has set their theme preference to light
or dark
by using the prefers-color-scheme
keyword.
This value can be used in a media query to change a website’s styles accordingly:
@media (prefers-color-scheme: dark) {
:root {
/* Update CSS variables */
}
}
However, it’s not possible for a website to alter this preference. That’s why it’s preferable to also add a data-theme
HTML attribute or a dark-theme
CSS class.
This is how AStral.CSS defines its dark theme:
@media (prefers-color-scheme: dark) {
:root {
/* Update CSS variables */
}
}
[data-theme=dark],
.dark-theme {
/* Update CSS variables */
}
With these rules:
- the website will be light by default, if no user preference is set
- it will also be light if the user has set their preference to
light
- the website will be dark if the user has set their preference to
dark
Force Dark Mode within a page
You can enable Dark Mode in part of your HTML by simply using the body attribute or the CSS class:
This is in Light Mode if the user hasn't set a preference, or if their preference is set to light
.
This is in Dark Mode
This is also in Dark Mode
Force Dark Mode for a whole webpage
If you want to enable Dark Mode for a whole webpage, simply set the attribute or the class on the <body>
element:
<body class="dark-theme"></body> <body data-theme="dark"></body>